# Homework 1

(Due date: January 17th @ 7:30 pm)

Presentation and clarity are very important! Show your procedure!

## PROBLEM 1 (50 PTS)

- Leading Zero Detector: This iterative circuit processes a 15-bit input (MSB first) and generates the number of leading 0's. before the first 1. Example:
  - $\checkmark~$  If the sequence is: 0000 0000 0011 010  $\rightarrow$  R = 10
  - $\checkmark~$  If the sequence is: 0001 0000 0011 010  $\rightarrow$  R = 3
  - ✓ If the sequence is: 0000 0000 1000 001  $\rightarrow$  R = 8
- The figure depicts the (in ASM form) and a datapath circuit. Note: Counters. If E=sclr=1, → Q=0. Input data: x (entered sequentially, MSB first). Output data R.
  - ✓ Complete the timing diagram of the digital circuit (next page). Note that 3 sequences are evaluated.
  - ✓ Write a structural VHDL code. You MUST create a file for i) modulo-(N+1) counter, ii) flip-flop, iii) Finite State Machine, and v) Top file (where you will interconnect all the components).
  - ✓ Write a testbench according to the timing diagram shown (next page). Simulate the circuit (Behavioral simulation). Verify that the simulation is correct by comparing it with the timing diagram you completed manually.
  - $\checkmark$  Upload the following files to <u>Moodle</u> (an assignment will be created):
    - VHDL code files
    - VHDL testbench



# ELECTRICAL AND COMPUTER ENGINEERING DEPARTMENT, OAKLAND UNIVERSITY ECE-3710: Computer Hardware Design



Winter 2019

2

P

done

ready

#### PROBLEM 2 (30 PTS)

- Period Counter: It measures the period of a periodic input waveform with a precision of 1 ms (from 1 ms to 1000 ms).
  - ✓ Inputs: x (input waveform), s (start signal).



- ✓ Clock frequency: 100 Mhz.
- Operation: The circuit takes a measurement when the s signal (usually a clock pulse) is asserted. This amounts to count the • number of cycles between two rising edges of the input waveform.
- However, to directly count the number of milliseconds, we can use a counter Q that counts up to 1 ms. Every time Q reaches 1 ms, we increase the count on another counter P, which will keep the number of milliseconds elapsed.
- The counter Q starts counting after the first rising edge is detected. When the second rising edge is detected, we assert done for a clock cycle. We are then ready to measure again should the signal s is asserted. The figure below shows an example for an input waveform whose period is 3 ms.



Sketch the circuit: FSM + Datapath components. Specify all the I/Os of the FSM, as well as the signals connecting the  $\checkmark$ FSM and the Datapath components.

Suggestion: The Datapath only needs two counters (Q and R) and a rising edge detector.

- Rising edge detector: It issues a one-cycle (10 ns) pulse on redg when it detects a rising edge on x.
- Counter O: 1 ms counter. For a clock period of 10 ns, it counts from 0 to  $10^{5}$ -1.
- Counter P: It stores the period of x in ms. This counter counts from 0 to 999.

You can use the standard counter with *enable* and *sclr* inputs. If using a rising edge detector block, sketch its design (e.g.: State Machine)

✓ Provide the State Diagram (in ASM form) of the FSM.

### PROBLEM 3 (20 PTS)

Calculate the result of the following operations, where the operands are signed integers. For the division, calculate both the quotient and the residue. No procedure = zero points.

| 10101 × | 01001 × | 101001 ÷ | 0111101 ÷ | 10011 ÷ |
|---------|---------|----------|-----------|---------|
| 11001   | 1011    | 10101    | 10110     | 0111    |